/**
 * Copyright 2021 The Vitess Authors.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
import React from 'react';

import { Icons } from '../Icon';
import { TextInput } from '../TextInput';
import style from './DataFilter.module.scss';

interface Props {
    autoFocus?: boolean;
    onChange?: React.ChangeEventHandler<HTMLInputElement>;
    onClear?: React.MouseEventHandler<HTMLButtonElement>;
    placeholder?: string;
    value?: string | null | undefined;
}

export const DataFilter = ({ autoFocus, onChange, onClear, placeholder, value }: Props) => {
    return (
        <div className={style.controls}>
            <TextInput
                autoFocus={autoFocus}
                iconLeft={Icons.search}
                onChange={onChange}
                placeholder={placeholder}
                value={value || ''}
            />
            <button className="btn btn-secondary" disabled={!value} onClick={onClear} type="button">
                Clear filters
            </button>
        </div>
    );
};
